import { defineConfig } from "vite";
import vue from "@vitejs/plugin-vue";
import path from "path";
import AutoImport from "unplugin-auto-import/vite";
import Components from "unplugin-vue-components/vite";
import { ElementPlusResolver } from "unplugin-vue-components/resolvers";
import ElementPlus from "unplugin-element-plus/vite";

import Unocss from "unocss/vite";

// https://vite.dev/config/
export default defineConfig({
  resolve: {
    alias: [
      {
        find: "@",
        replacement: path.resolve(__dirname, "src")
      }
    ]
  },
  plugins: [
    vue(),
    Unocss(),
    AutoImport({
      // api的自动导入
      imports: ["vue", "pinia", "vue-router"],
      resolvers: [ElementPlusResolver()],
      eslintrc: { enabled: false }
    }),
    Components({
      // 组件的自动导入
      resolvers: [ElementPlusResolver()],
      dirs: ["src/components", "src/layout/components"]
    }),
    ElementPlus({})
  ],
  server: {
    proxy: {
      "/dev-api": {
        target: "",
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/dev-api/, "/api")
      }
    }
  }
});
